import router from './router'
import store from './store'
import nProgress from 'nprogress'
import 'nprogress/nprogress.css'
// 设置白名单(不需要token的页面)
const pageArr = ['/404', '/login']

// 导航前置守卫
nProgress.start()
router.beforeEach(async (to, from, next) => {
  // 如果有token
  if (store.getters.token) {
    // 如果进入的是login页面
    if (to.path.toLowerCase() === '/login') {
      // 让它直接进入主页
      next('/')
    } else {
      // 验证token,获取用户个人信息
      // 如果有用户信息就不用再次获取(不用每次都调用接口,很冗余)
      if (!store.state.user.userInfo.userId) {
        await store.dispatch('user/getUserInfo')
        next(to.fullPath)
      } else {
        next()
      }
    }
  } else {
    // 如果没有token
    // 如果进入了不需要token的白名单页面
    if (pageArr.includes(to.path.toLowerCase())) {
      next()
    } else {
      next(`/login?redirect=${encodeURIComponent(to.fullPath)}`)
    }
  }
  nProgress.done()
})
